组合式 API:依赖注入

您所在的位置:网站首页 vue provide inject官网 组合式 API:依赖注入

组合式 API:依赖注入

2023-10-24 00:14| 来源: 网络整理| 查看: 265

类型

ts// 没有默认值 function inject(key: InjectionKey | string): T | undefined // 带有默认值 function inject(key: InjectionKey | string, defaultValue: T): T // 使用工厂函数 function inject( key: InjectionKey | string, defaultValue: () => T, treatDefaultAsFactory: true ): T

详细信息

第一个参数是注入的 key。Vue 会遍历父组件链,通过匹配 key 来确定所提供的值。如果父组件链上多个组件对同一个 key 提供了值,那么离得更近的组件将会“覆盖”链上更远的组件所提供的值。如果没有能通过 key 匹配到值,inject() 将返回 undefined,除非提供了一个默认值。

第二个参数是可选的,即在没有匹配到 key 时使用的默认值。

第二个参数也可以是一个工厂函数,用来返回某些创建起来比较复杂的值。在这种情况下,你必须将 true 作为第三个参数传入,表明这个函数将作为工厂函数使用,而非值本身。

与注册生命周期钩子的 API 类似,inject() 必须在组件的 setup() 阶段同步调用。

当使用 TypeScript 时,key 可以是一个类型为 InjectionKey 的 symbol。InjectionKey 是一个 Vue 提供的工具类型,继承自 Symbol,可以用来同步 provide() 和 inject() 之间值的类型。

示例

假设有一个父组件已经提供了一些值,如前面 provide() 的例子中所示:

vue import { inject } from 'vue' import { fooSymbol } from './injectionSymbols' // 注入不含默认值的静态值 const foo = inject('foo') // 注入响应式的值 const count = inject('count') // 通过 Symbol 类型的 key 注入 const foo2 = inject(fooSymbol) // 注入一个值,若为空则使用提供的默认值 const bar = inject('foo', 'default value') // 注入一个值,若为空则使用提供的函数类型的默认值 const fn = inject('function', () => {}) // 注入一个值,若为空则使用提供的工厂函数 const baz = inject('factory', () => new ExpensiveObject(), true)

参考

指南 - 依赖注入指南 - 为 provide/inject 标注类型


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3